

# **Data Sheet For 80186EC Core**



## **DOCUMENT REVISION HISTORY**

| Revision                                            | Date                                                                           | Change Description                                                                                                                                                                                                                                                                                                                    | Author                                                                                                                  |  |
|-----------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|
| R1.0 and 27 <sup>th</sup> Nov.<br>REL 1.0 2013      |                                                                                | First Release                                                                                                                                                                                                                                                                                                                         | Ranjith KB                                                                                                              |  |
| intended r<br>Any revie<br>intended r<br>disclosure | ecipient(s). Do<br>w, use, distribu<br>ecipient (or aut<br>c, copy or distribu | CE: This document contains proprietary material on the read this document further if you are not read this document further if you are not or disclosure by others is strictly prohesticated to receive for the recipient), you are bution or use of any of the information contract. TED. Thank you. " <i>i</i> Wave Systems Tech. I | not the intended recipient.<br>ibited. If you are not the<br>re hereby notified that any<br>tained within this document |  |



## **Table of Contents**

| 1 | INTRODUCTION                                           | 6  |
|---|--------------------------------------------------------|----|
|   | 1.1 PURPOSE                                            | 6  |
|   | 1.2 Features                                           |    |
|   | 1.3 FEATURES NOT SUPPORTED                             |    |
|   | 1.4 ACRONYMS AND ABBREVIATIONS                         |    |
| 2 | 80186EC CORE                                           | 9  |
|   | 2.1 BLOCK DIAGRAM                                      |    |
|   | 2.2 DESCRIPTION                                        | 10 |
|   | 2.3 I/O SIGNAL DESCRIPTION                             | 11 |
| 3 | 3 TIMING WAVEFORMS                                     | 16 |
|   | 3.1 CPU WRITE CYCLE                                    | 16 |
|   | 3.1.1 CPU Write Cycle (RDY = 0 and without wait state) | 16 |
|   | 3.1.2 CPU Write Cycle (RDY = 0 and with wait state)    |    |
|   | 3.1.3 CPU Write Cycle (RDY = 1)                        | 17 |
|   | 3.2 CPU READ CYCLE                                     |    |
|   | 3.2.1 CPU Read Cycle                                   | 18 |
|   | 3.3 INTERRUPT ACKNOWLEDGE CYCLE                        |    |
|   | 3.3.1 Interrupt Acknowledge Cycle                      | 19 |
|   | 3.4 HOLD/HACK CYCLE                                    | 20 |
|   | 3.4.1 HOLD/HACK Cycle                                  |    |
|   | 3.5 HALT CYCLE                                         |    |
|   | 3.5.1 HALT Cycle                                       | 21 |
| 4 | IMPLEMENTATION RESULTS                                 | 22 |



## **List of Figures**

| Figure 1: 80186EC Core Block Diagram                       | 9  |
|------------------------------------------------------------|----|
| Figure 2: CPU Write Cycle (RDY = 0 and Without wait state) | 16 |
| Figure 3: CPU Write Cycle (RDY = 0 and With wait state)    | 17 |
| Figure 4: CPU Write Cycle (RDY = 1)                        | 17 |
| Figure 5: CPU Read Cycle                                   | 18 |
| Figure 6: Interrupt Acknowledge Cycle                      |    |
| Figure 7: HOLD/HACK Cycle                                  |    |
| Figure 8: HALT Cycle                                       | 21 |



## **List of Tables**

| Table 1: Acronyms & Abbreviations                           | 8  |
|-------------------------------------------------------------|----|
| Table 2: 80186EC Core IO Signals—not finished               | 11 |
| Table 3: Device Utilization Summary for Actel ProASIC3      |    |
| Table 4: Device Utilization Summary for Xilinx Spartan6     | 22 |
| Table 5: Device Utilization Summary for Altera Cyclone IV E |    |
| Table 6: Device Utilization Summary for Lattice XP2         |    |



## **1** Introduction

### 1.1 Purpose

The iW-80186EC is a powerful 16-bit microprocessor core, executes instruction list compatible with 80186EC microprocessor. The design along with multiple peripherals can be fit into single FPGA.

### **1.2 Features**

The following are the main features of the 80186EC Core:

- iW-80186EC CPU Core
  - Multiplexed 20-bit address and 16-bit data bus
  - 1M-byte memory space divided into 4 segments
  - 64K-byte IO space
  - Non Maskable Interrupt support
  - Arithmetic-Logic Unit
    - 8,16,32-bit arithmetic operations
    - 8,16-bit logical operations
    - Boolean manipulations
    - 16 x 16 bit multiplication (signed or unsigned)
    - 32/16-bit division (signed or unsigned)
- CPU On-Chip Peripherals
  - Programmable Timer / Counter Unit
    - Three programmable independent 16-bit timers
    - TOUT0 to TOUT1 pin outputs
    - TIN0 & TIN1 used either as clock or control signals
    - Timer-2 can be used to clock other two timers
    - Internal / external input clock selectable
  - Serial Communications Unit
    - RS-232-C protocol support (on-chip CTS\_N, SINT\_N pins)
    - Only asynchronous mode is supported
    - Two independent identical channels
    - Full duplex operation in asynchronous mode
    - Programmable seven, eight or nine data bits in asynchronous mode



- Independent baud rate generator
- Double-buffered transmit and receive
- Clear-to-Send feature for transmission
- Break character transmission and detection
- Programmable even, odd or no parity
- Detects both framing and overrun errors
- Supports interrupt on transmit and receive
- Interrupt Controller Unit
  - Edge trigger / level trigger selectable
  - Individually maskable interrupt requests
  - Programmable interrupt request priority orders
  - Supports Cascading and polling mode
  - 8 external interrupt request inputs (INTx ; x=0,1,2,...,7)
  - 7 internal interrupt input pins (SCU, TCU, and DMAU)
- Chip Select Unit
  - Ten programmable chip-select outputs
  - Programmable start and stop addresses
  - Memory or I/O bus cycle decoder
  - Programmable wait-state generator
  - Provision to disable a chip-select
  - Provision to override bus ready
- Direct Memory Access Unit
  - four DMA channels can be accessed independently
  - priority of channels can be modified using priority registers.
  - DMA requests can be masked by DMA HALT registers.
  - four separate External DMA requests pins.
  - internal requests either by timer.
  - programmable software request to start the DMA.
  - The four channel DMAs are integrated using two channel module.
- Watchdog Timer Unit
  - 32-bit down counter used,
  - reload and disable option for the watchdog timer.



- Asserts a signal to indicate if the program hangs, or some infinite loop occurs.
- Multiplexed general purpose Input Output port
  - Three ports of total having 22 pins
  - A 8 pin inout port multiplexed with the Serial controller unit
  - A 8 pin output port multiplexed with Chip Select Unit.
  - A 6 pin output port multiplexed with DMA and SCU interrupts(4 pins) and two pins as general purpose inouts.
- Clock Generator

### **1.3 Features Not Supported**

- Crystals cannot be directly connected to the FPGA (External clock input required for FPGA)
- ONCE mode
- Power down modes
- Refresh Control Unit
- WAIT instruction is not supported
- Synchronous mode in Serial Communication Unit

#### 1.4 Acronyms and Abbreviations

#### Table 1: Acronyms & Abbreviations

| Term | Meaning                       |
|------|-------------------------------|
| FPGA | Field Programmable Gate Array |
| CPU  | Central Processing Unit       |
| I/O  | Input/ Output                 |
| DMAU | Direct Memory Access Unit     |
| BIU  | Bus Interface Unit            |
| CSU  | Chip Select Unit              |
| TCU  | Timer Control Unit            |
| ICU  | Interrupt Control Unit        |
| SCU  | Serial Control Unit           |
| IOPU | Input Output Port Unit        |



## 2 80186EC Core

### 2.1 Block Diagram







### 2.2 Description

The main blocks in 80186EC Core:

- **Central Processing Unit** (**CPU**): This module executes instructions, which include fetching, decoding instructions and generating appropriate requests to the Bus Interface Unit.
- **Timer / Counter Unit (TCU):** This module provides three programmable 16-bit timer/counters. Two of these are highly flexible and are connected to external pins for control or clocking. A third timer is not connected to any external pins and can only be clocked internally.
- Serial Communications Unit (SCU): This module supports both synchronous and asynchronous communications modes and contains two independent channels. Each channel has its own baud rate generator that is independent of the TCU, and can be internally or externally clocked at up to one half of the operating frequency.
- Interrupt Control Unit (ICU): This module serves 8 external interrupts and 7 internal interrupts, using master and slave 8259 programmable interrupt controller. The master 8259A module offers the ability to cascade to up to seven other 8259A modules. This arrangement is used to expand the interrupt handling capability of an 80C186EC system to 57 external sources.
- **Chip-Select Unit (CSU):** This module integrates logic, which provides up to ten programmable chip selects to access both memories and peripherals. Besides selecting a specific device, each chip-select can be used to control the number of wait states inserted into the bus cycle
- I/O Port Unit (IOPU): This module supports two 8-bit channels of input, output, or input/output operation
- **DMAU:** This module supports Direct memory access with 4 channels, with MEM/IO to IO/MEM transfers or vice versa.
- **WDTU:** Watchdog unit continuously monitor the system operation for any hang-outs or indefinite loops in execution.
- **Clock Generator:** This module generates both internal and external clock



## 2.3 I/O Signal Description

#### Table 2: 80186EC Core IO Signals—not finished

| Signal                                | I/O | Width | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------------|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESIN_N_I                             | Ι   | 1     | An active low signal causes the processor to<br>immediately terminate any bus cycle in progress<br>and assume an initialized state. All pins will be<br>driven to a known state, and RESOUT will also<br>be driven active.                                                                                                                                                                      |
| RESOUT_O                              | 0   | 1     | Indicates the processor is currently in the reset<br>state. RESOUT will remain active as long as<br>RESIN_N remains active.                                                                                                                                                                                                                                                                     |
| CLKIN_I                               | Ι   | 1     | External clock input operating at two times the processor operating frequency.                                                                                                                                                                                                                                                                                                                  |
| CLKOUT_O                              | 0   | 1     | Processor Clock output. It is half of Clock input (CLKIN_I).                                                                                                                                                                                                                                                                                                                                    |
| A19/S6,<br>A18/S5<br>A17/S4<br>A16/S3 | I/O | 1     | These pins drive address information during the<br>address phase of the bus cycle. During T2 and<br>T3 these pins drive status information. S6 is low<br>to indicate CPU bus cycles and high to indicate<br>DMA or refresh bus cycles. S3 to S6 are always<br>0 on the 80C186EC.                                                                                                                |
| AD15/CAS2<br>AD14/CAS1<br>AD13/CAS0   | I/O | 1     | These pins are part of the multiplexed<br>ADDRESS and DATA bus. During the address<br>phase of the bus cycle, address bits 15 through<br>13 are presented on these pins and can be latched<br>using ALE. Data information is transferred<br>during the data phase of the bus cycle. Pins<br>AD15:13/CAS2:0 drive the<br>82C59 slave address information during interrupt<br>acknowledge cycles. |
| AD_IO                                 | I/O | 13    | These pins provide a multiplexed ADDRESS<br>and DATA bus. During the address phase of the<br>bus cycle, address bits 0 through 12 are<br>presented on the bus and can be latched using<br>ALE. Data information is transferred during the<br>data phase of the bus cycle.                                                                                                                       |



### Data Sheet for 80186EC Core R1.0 REL 1.0

| Signal     | I/O | Width |                                                                                                                                                                                          | Desc             | ription                                                          |                                                                    |
|------------|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------|--------------------------------------------------------------------|
| BHE_N_O    | 0   | 1     | Byte High Enable output indicates that the bus<br>cycle in progress is transferring data over the<br>upper half of the data bus. BHE and A0 have th<br>following logical encoding scheme |                  | over the                                                         |                                                                    |
|            |     |       | A0         BH1           0         0           0         1           1         0           1         1                                                                                   |                  | Encoding<br>Word Transfe<br>Even byte tra<br>Odd byte tran<br>NA | nsfer                                                              |
| ALE_O      | 0   | 1     |                                                                                                                                                                                          |                  | an active high<br>nation into a t                                | n signal used                                                      |
| S_N_O[2:0] | 0   | 3     | type latch du<br>cycle.<br>Bus cycle St                                                                                                                                                  | tatus are end    | dress phase c<br>coded on thes<br>information.                   | of the bus<br>se pins to                                           |
|            |     |       | 0<br>0<br>0<br>0                                                                                                                                                                         | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1                                                 | Interrupt<br>Acknowl<br>edge<br>Read I/O<br>Write I/O<br>Processor |
|            |     |       | 1                                                                                                                                                                                        | 0                | 0                                                                | HALT<br>Queue<br>Instructio<br>n Fetch                             |
|            |     |       | 1                                                                                                                                                                                        | 0                | 1                                                                | Read<br>Memory                                                     |
|            |     |       | 1                                                                                                                                                                                        | 1                | 0                                                                | Write<br>Memory                                                    |
|            |     |       | 1                                                                                                                                                                                        | 1                | 1                                                                | Passive(n<br>o bus<br>activity)                                    |



| Signal   | I/O | Width | Description                                         |
|----------|-----|-------|-----------------------------------------------------|
| C        |     |       | -                                                   |
| READY_I  | Ι   | 1     | Active high Ready input to signal the completion    |
|          |     |       | of a bus cycle. It must be active to terminate any  |
|          |     |       | bus cycle, unless it is ignored by correctly        |
|          |     |       | programming the Chip-Select Unit.                   |
| RD_N_O   | 0   | 1     | Active low Read output signals that the accessed    |
|          |     |       | memory or I/O device must drive data                |
|          |     |       | information onto the data bus.                      |
| WR_N_O   | 0   | 1     | Active low Write output signals that data           |
|          |     |       | available on the data bus are to be written into    |
|          |     |       | the accessed memory or I/O device.                  |
| DEN_N_O  | 0   | 1     | Active low Data enable output to control the        |
|          |     |       | enable of bi-directional transceivers in a buffered |
|          |     |       | system. DEN is active only when data is to be       |
|          |     | _     | transferred on the bus.                             |
| DT_R_O   | 0   | 0     | Data Transmit/Receive output controls the           |
|          |     |       | direction of a bi-directional buffer in a buffered  |
|          |     |       | system.                                             |
| HOLD_I   | Ι   | 1     | HOLD request input to signal that an external       |
|          |     |       | bus master wishes to gain control of the local      |
|          |     |       | bus.                                                |
| HLDA_O   | 0   | 1     | The processor generates HLDA in response to a       |
|          |     |       | HOLD indicating that bus is granted. It indicates   |
|          |     |       | that the processor has relinquished control of the  |
|          |     |       | local bus.                                          |
| LOCK_N_O | 0   | 1     | The processor will not service other bus requests   |
|          |     |       | (such as HOLD) while LOCK is active.                |
| NMI I    | Ι   | 1     | Non-Maskable Interrupt input causes a TYPE-2        |
|          |     |       | interrupt to be serviced by the CPU. NMI is         |
|          |     |       | latched internally.                                 |
| UCS_N_O  | 0   | 1     | Upper Chip Select will go active whenever the       |
|          | _   |       | address of a memory or I/O bus cycle is within      |
|          |     |       | the address limitations programmed by the user.     |
| LCS_N_O  | 0   | 1     | Lower Chip Select will go active whenever the       |
|          | -   |       | address of a memory bus cycle is within the         |
|          |     |       | address limitations programmed by the user.         |
|          |     | 1     |                                                     |



| Signal                                                                              | I/O | Width | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P1_0_GCS0_N_O<br>to<br>P1_7_GCS7_N_O                                                | 0   | 1     | These pins provide a multiplexed function. If<br>enabled, each pin can provide a Generic Chip<br>Select output, which will go active whenever, the<br>address of a memory or I/O bus cycle is within<br>the address limitations programmed by the user.<br>When not programmed as a Chip-Select, each<br>pin may be used as a general-purpose output<br>Port. As an output port pin, the value of the pin<br>can be read internally. |
| T0OUT0_0, T1OUT1_0                                                                  | 0   | 1     | Timer output pins can be programmed to provide<br>a single clock or continuous waveform<br>generation, depending on the timer mode<br>selected.                                                                                                                                                                                                                                                                                      |
| T0IN0_I,T1IN1_I                                                                     | Ι   | 1     | Timer input is used either as clock or control signals, depending on the timer mode selected.                                                                                                                                                                                                                                                                                                                                        |
| INT0_I,<br>INT1_I,<br>INT2_I,<br>INT3_I,<br>INT4_I,<br>INT5_I,<br>INT6_I,<br>INT7_I | I   | 1     | Maskable interrupt input will cause a vector to a<br>specific type interrupt routine. The INT6:0 pins<br>can be used as cascade inputs from slave 8259A<br>devices. The INT pins can be configured as level<br>or edge sensitive                                                                                                                                                                                                     |
| INTA_O                                                                              | 0   | 1     | Interrupt Acknowledge output is a handshaking<br>signal used by external 82C59A Programmable<br>Interrupt Controllers.                                                                                                                                                                                                                                                                                                               |
| P3_5_IO,<br>P3_4_IO                                                                 | I/O | 1     | Bidirectional, open-drain port pins.                                                                                                                                                                                                                                                                                                                                                                                                 |
| P3_3_DMAI1_O,<br>P3_2_DMAI0_O                                                       | 0   | 1     | DMA Interrupt output goes active to indicate that<br>the channel has completed a transfer. DMAI1<br>and DMAI0 are multiplexed with output only<br>port functions.                                                                                                                                                                                                                                                                    |
| P3_1_TXI1_O                                                                         | 0   | 1     | Transmit Interrupt output goes active to indicate<br>that serial channel 1 has completed a transfer.<br>TXI1 is multiplexed with an output only Port<br>function.                                                                                                                                                                                                                                                                    |
| P3_0_RXI1_O                                                                         | 0   | 1     | Receive Interrupt output goes active to indicate<br>that serial channel 1 has completed a reception.<br>RXI1 is multiplexed with an output only port<br>function.                                                                                                                                                                                                                                                                    |



| Signal                                  | I/O | Width | Description                                                                                                                                                                                                                                                          |
|-----------------------------------------|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WDTOUT_N_O                              | 0   | 1     | WatchDog Timer output is driven low for four<br>clock cycles when the watchdog timer reaches<br>zero. WDTOUT may be ANDed with the power-<br>on reset signal to reset the processor when the<br>watchdog timer is not properly reset.                                |
| P2_7_CTS1_IO<br>P2_3_CTS0_IO            | I/O | 1     | Clear-To-Send input is used to prevent the<br>transmission of serial data on the TXD signal<br>pin. CTS1 and CTS0 are multiplexed with an I/O<br>Port function.                                                                                                      |
| P2_6_BCLK1_IO<br>P2_2_BCLK0_IO          | I/O | 1     | Baud Clock input can be used as an alternate<br>clock source for each of the integrated serial<br>channels. The BCLK inputs are multiplexed with<br>I/O Port functions. The BCLK input frequency<br>cannot exceed (/2 the operating frequency of the<br>processor.   |
| P2_5_TXD1_IO<br>P2_1_TXD0_IO            | I/O | 1     | Transmit Data output provides serial data<br>information. The TXD outputs are multiplexed<br>with I/O Port functions. During synchronous<br>serial communications, TXD will function as a<br>clock output.                                                           |
| P2_4_RXD1_IO<br>P2_0_RXD0_ IO           | I/O | 1     | Receive Data input accepts serial data<br>information. The RXD pins are multiplexed with<br>I/O Port functions. During synchronous serial<br>communications, RXD is bi-directional and will<br>become an output for transmission of data (TXD<br>becomes the clock). |
| DRQ3_O,<br>DRQ2_O,<br>DRQ1_O,<br>DRQ0_O | 0   | 1     | DMA Request input pins are used to request a<br>DMA transfer. The timing of the request is<br>dependent on the programmed synchronization<br>mode.                                                                                                                   |



## **3** Timing Waveforms

## 3.1 CPU Write Cycle

#### **3.1.1** CPU Write Cycle (RDY = 0 and without wait state)



Figure 2: CPU Write Cycle (RDY = 0 and Without wait state)



#### **3.1.2** CPU Write Cycle (RDY = 0 and with wait state)



Figure 3: CPU Write Cycle (RDY = 0 and With wait state)





Figure 4: CPU Write Cycle (RDY = 1)



## 3.2 CPU Read Cycle

#### 3.2.1 CPU Read Cycle



Figure 5: CPU Read Cycle



## 3.3 Interrupt Acknowledge Cycle

### 3.3.1 Interrupt Acknowledge Cycle







## 3.4 HOLD/HACK Cycle

### 3.4.1 HOLD/HACK Cycle



Figure 7: HOLD/HACK Cycle



## 3.5 HALT Cycle

#### 3.5.1 HALT Cycle



Figure 8: HALT Cycle



## **4** Implementation Results

The table below shows the utilization summary from the implementation of 80186EC Core for different FPGA devices.

Table 3: Device Utilization Summary for Actel ProASIC3

| Logic Utilization   | Used  |
|---------------------|-------|
| Number of Core SEQ  | 3661  |
| Number of Core COMB | 17991 |
| RAM/FIFO            | 1     |
| Number of IOs       | 80    |

#### Table 4: Device Utilization Summary for Xilinx Spartan6

| Logic Utilization         | Used |
|---------------------------|------|
| Number of Slice Registers | 3449 |
| Number of Slice LUTs      | 6612 |
| DSP48A1s                  | 2    |
| Number of IOs             | 80   |

#### Table 5: Device Utilization Summary for Altera Cyclone IV E

| Logic Utilization                      | Used |
|----------------------------------------|------|
| Number of Logic Elements combinational | 9467 |
| Number of Logic Elements registers     | 3599 |
| Embedded Multiplier 9-bit elements     | 4    |
| Number of Pins                         | 80   |

#### Table 6: Device Utilization Summary for Lattice XP2

| Logic Utilization         | Used |
|---------------------------|------|
| Number of Slice registers | 3808 |
| Number of Slice LUTs      | 9833 |
| DSP Components MULT18X18C | 2    |
| Number of PIO             | 80   |